body {
  margin: 0;
  font-family: 'Poppins', sans-serif;
  cursor: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="18" height="18" viewBox="0 0 24 24"><path fill="%23FFF" stroke="%23000" stroke-width="2" d="M5.5 3.21V20.8c0 .45.54.67.85.35l4.86-4.86a.5.5 0 0 1 .35-.15h6.87a.5.5 0 0 0 .35-.85L6.35 2.85a.5.5 0 0 0-.85.35Z"/></svg>') 0 0, auto;
}

body.no-scroll {
  overflow: hidden;
}


[role="button"],
[tabindex],
a,
button,
input[type="button"],
input[type="submit"],
label,
select,
textarea,
summary {
  cursor: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24'><path fill='%23FFF' stroke='%23000' stroke-width='2' stroke-linejoin='round' d='M10 11V8.99c0-.88.59-1.64 1.44-1.86h.05A1.99 1.99 0 0 1 14 9.05V12v-2c0-.88.6-1.65 1.46-1.87h.05A1.98 1.98 0 0 1 18 10.06V13v-1.94a2 2 0 0 1 1.51-1.94h0A2 2 0 0 1 22 11.06V14c0 .6-.08 1.27-.21 1.97a7.96 7.96 0 0 1-7.55 6.48 54.98 54.98 0 0 1-4.48 0 7.96 7.96 0 0 1-7.55-6.48C2.08 15.27 2 14.59 2 14v-1.49c0-1.11.9-2.01 2.01-2.01h0a2 2 0 0 1 2.01 2.03l-.01.97v-10c0-1.1.9-2 2-2h0a2 2 0 0 1 2 2V11Z'/></svg>") 4 4, pointer;
}

.logo-text { display: flex; flex-direction: column; }

.navbar {
  width: 100%;
  background-color: #fff;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
  font-size: 16px;
}

.navbar-main {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 15px 20px;
}

.logo {
  display: flex;
  align-items: center;
}

.logo img {
  width: 75px;
  height: 75px;
  margin-left: 10px;
}

body {
  font-family: "Poppins", sans-serif;
}

.dropdown-item {
  position: relative;
  overflow: hidden;
  z-index: 1;
  transition: color 0.2s ease;
}

.dropdown-item::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  width: 0;
  height: 100%;
  transition: all 0.6s ease;
  z-index: -1;
  transform: translateX(-50%);
}

 .dropdown-pink .dropdown-item {
  color: #ff1a57;
}

.dropdown-pink .dropdown-item::before {
  background-color: #ff1a57;
}

.dropdown-pink .dropdown-item:hover {
  color: white;
}

.dropdown-pink .dropdown-item:hover::before {
  width: 100%;
}

.dropdown-blue .dropdown-item {
  color: #7405BC;
}

.dropdown-blue .dropdown-item::before {
  background-color: #7405BC;
}

.dropdown-blue .dropdown-item:hover {
  color: white;
}

.dropdown-blue .dropdown-item:hover::before {
  width: 100%;
}

.dropdown-green .dropdown-item {
  color:#00bcd4;
}

.dropdown-green .dropdown-item::before {
  background-color:#00bcd4;
}

.dropdown-green .dropdown-item:hover {
  color: white;
}

.dropdown-green .dropdown-item:hover::before {
  width: 100%;
}

.dropdown-purple .dropdown-item {
  color: #7405BC;
}

.dropdown-purple .dropdown-item::before {
  background-color: #7405BC;
}

.dropdown-purple .dropdown-item:hover {
  color: white;
}

.dropdown-purple .dropdown-item:hover::before {
  width: 100%;
}

.dropdown-orange .dropdown-item {
  color: #FF4301;
}

.dropdown-orange .dropdown-item::before {
  background-color: #FF4301;
}

.dropdown-orange .dropdown-item:hover {
  color: white;
} 
.dropdown-orange .dropdown-item:hover::before {
  width: 100%;
}

.dropdown-pink,
.dropdown-blue,
.dropdown-green,
.dropdown-purple,
.dropdown-orange {
  background-color: white;
}


.dot:hover {
  transform: scale(1.2);
  opacity: 0.9;
}


#preloader {
  position: fixed;
  width: 100%;
  height: 100%;
  background: white;
  color: #FF4401;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  font-family: sans-serif;
}

.loader {
  position: fixed;
  bottom: 40px;
  right: 40px;
  background: rgba(255, 255, 255, 0.1);
  padding: 10px 15px;
  border-radius: 8px;
  font-size: 48px;
  z-index: 10000;
  display: flex;
  align-items: center;
  gap: 6px;
  font-weight: bold;
}

.loader div {
  text-align: center;
}

.loader-text span.char {
  opacity: 0;
  display: inline-block;
  font-size: 76px;
  font-weight: 700;
}

.stroke-text {
  -webkit-text-stroke-width: 1px;
  -webkit-text-stroke-color: #FF4401;
  color: transparent !important;
}

body.loaded #preloader {
  display: none;
}

.no-scrollbar::-webkit-scrollbar {
  display: none;
}

.no-scrollbar {
  -ms-overflow-style: none;
  scrollbar-width: none;
}

.group:hover .group-hover\:scale-100 {
  transform: scale(1);
}

.group:not(:hover) .group-hover\:scale-100 {
  transform: scale(0);
}

.testimonial-section:hover .quote-icon {
  background-color: white;
  color: yellow;
  border-color: white;
  transform: scale(1.1);
}

#learn-more-btn {
  --fs: 1.25em;
  --col1: honeydew;
  --col2: rgba(240, 128, 128, 0.603);
  --col3: indianred;
  --col4: maroon;
  --pd: .5em .65em;
  display: grid;
  align-content: center;
  appearance: none;
  border: 0;
  grid-template-columns: min-content 1fr;
  padding: var(--pd);
  font-size: var(--fs);
  color: var(--col1);
  background-color: var(--col3);
  border-radius: 6px;
  transition: all .75s ease-out;
  transform-origin: center;
  margin-top: 20px;
  margin-left: 5px;
}

#learn-more-btn:active {
  animation: offset 1s ease-in-out infinite;
  outline: 2px solid var(--col2);
  outline-offset: 0;
}

#learn-more-btn::after,
#learn-more-btn::before {
  content: '';
  align-self: center;
  justify-self: center;
  height: .5em;
  margin: 0 .5em;
  grid-column: 1;
  grid-row: 1;
  opacity: 1;
}

#learn-more-btn::after {
  position: relative;
  border: 2px solid var(--col4);
  border-radius: 50%;
  transition: all .5s ease-out;
  height: .1em;
  width: .1em;
}

#learn-more-btn:hover::after {
  border: 2px solid var(--col3);
  transform: rotate(-120deg) translate(10%, 140%);
}

#learn-more-btn::before {
  border-radius: 50% 0%;
  border: 4px solid var(--col4);
  box-shadow: inset 1px 1px var(--col2);
  transition: all 1s ease-out;
  transform: rotate(45deg);
  height: .45em;
  width: .45em;
}

#learn-more-btn:hover::before {
  border-radius: 50%;
  border: 4px solid var(--col1);
  transform: scale(1.25) rotate(0deg);
  animation: blink 1.5s ease-out 1s infinite alternate;
}

#learn-more-btn:hover>span {
  filter: contrast(150%);
}

@keyframes blink {
  0% {
    transform: scale(1, 1) skewX(0deg);
    opacity: 1;
  }

  5% {
    transform: scale(1.5, .1) skewX(10deg);
    opacity: .5;
  }

  10%,
  35% {
    transform: scale(1, 1) skewX(0deg);
    opacity: 1;
  }

  40% {
    transform: scale(1.5, .1) skewX(10deg);
    opacity: .25;
  }

  45%,
  100% {
    transform: scale(1, 1) skewX(0deg);
    opacity: 1;
  }
}

@keyframes offset {
  50% {
    outline-offset: .15em;
    outline-color: var(--col1);
  }

  55% {
    outline-offset: .1em;
    transform: translateY(1px);
  }

  80%,
  100% {
    outline-offset: 0;
  }
}

.fade-in {
  animation: fadeInUp 0.5s ease forwards;
}

@keyframes fadeInUp {
  0% {
    opacity: 0;
    transform: translate(calc(-40px + 80px * var(--random-x)),
        calc(40px - 80px * var(--random-y)));
  }

  100% {
    opacity: 1;
    transform: translate(0, 0);
  }
}

.hover-card {
  transition: transform 0.3s ease;
}

.hover-card:hover {
  transform: scale(1.02);
}

.hover-overlay {
  background: rgba(0, 0, 0, 0.5);
}

.search-btn {
  background-color: #d4ff5e;
  width: 3rem;
  height: 3rem;
  border-radius: 9999px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

.group:hover .search-btn {
  opacity: 1;
  transform: scale(1);
}

.search-btn {
  transform: scale(0.8);
  opacity: 0;
}

.group:hover .caption {
  opacity: 1;
  transform: translateY(0);
}

.caption {
  transform: translateY(10px);
  opacity: 0;
  transition: all 0.3s ease;
}


.btn-cart {
  display: flex;
  align-items: center;
  justify-content: center;
  bottom: 4px;
  right: 6px;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  border: none;
  background-color: transparent;
  position: relative;
  cursor: pointer;
  padding: 0;
}

.btn-cart::after {
  content: attr(data-quantity);
  position: absolute;
  font-size: 12px;
  color: #ba22e9;
  font-weight: bold;
  opacity: 0;
  visibility: hidden;
  transition: 0.2s ease-in-out;
  top: 110%;
}

.icon-cart {
  width: 20px;
  height: 25px;
  transition: 0.2s ease-in-out;
}

.icon-cart path {
  fill: #f00808;
  transition: 0.2s ease-in-out;
}

.btn-cart:hover>.icon-cart {
  transform: scale(1.15);
}

.btn-cart:hover>.icon-cart path {
  fill: #ba22e9;
}

.btn-cart:hover::after {
  visibility: visible;
  opacity: 1;
  top: 100%;
}

.quantity {
  display: none;
}

.view-toggle {
  cursor: pointer;
  border-radius: 8px;
  padding: 3px;
  transition: all 0.3s;
  display: flex;
  align-items: center;
  justify-content: center;
}

.view-dot {
  background: #ccc;
  border: 1px solid #aaa;
  border-radius: 2px;
  transition: all 0.3s;
}

.view-toggle.active .view-dot {
  background: #000 !important;
  border-color: #333 !important;
  transform: scale(0.92);
}

.cartBtn {
  width: 155px;
  height: 40px;
  border: none;
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  color: white;
  font-weight: 500;
  position: relative;
  background-color: rgb(29, 29, 29);
  box-shadow: 0 20px 30px -7px rgba(27, 27, 27, 0.219);
  transition: all 0.3s ease-in-out;
  cursor: pointer;
  overflow: hidden;
}

.cart {
  z-index: 2;
}

.cartBtn:active {
  transform: scale(0.96);
}

.product {
  position: absolute;
  width: 12px;
  border-radius: 3px;
  content: "";
  left: 23px;
  bottom: 23px;
  opacity: 0;
  z-index: 1;
  fill: rgb(211, 211, 211);
}

.cartBtn:hover .product {
  animation: slide-in-top 1.2s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
}

@keyframes slide-in-top {
  0% {
    transform: translateY(-30px);
    opacity: 1;
  }

  100% {
    transform: translateY(0) rotate(-90deg);
    opacity: 1;
  }
}

.cartBtn:hover .cart {
  animation: slide-in-left 1s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
}

@keyframes slide-in-left {
  0% {
    transform: translateX(-10px);
    opacity: 0;
  }

  100% {
    transform: translateX(0);
    opacity: 1;
  }
}

@media (max-width: 360px) {
  .navbar-main {
    padding: 10px 15px;
  }

  .logo img {
    width: 50px;
    height: 50px;
  }

  .logo-text {
    font-size: 18px;
  }

  .loader {
    bottom: 20px;
    right: 20px;
    font-size: 36px;
  }

  .loader-text span.char {
    font-size: 56px;
  }
}

@media (min-width: 361px) and (max-width: 480px) {
  .navbar-main {
    padding: 12px 15px;
  }

  .logo img {
    width: 60px;
    height: 60px;
  }

  .logo-text {
    font-size: 20px;
  }
}

@media (min-width: 481px) and (max-width: 768px) {
  .navbar-main {
    padding: 15px 20px;
  }
}

@media (min-width: 769px) and (max-width: 1024px) {}

@media (min-width: 1025px) {
  .navbar-main {
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px 30px;
  }

  .logo img {
    width: 130px;
    height: 130px;
  }

  .logo-text {
    font-size: 28px;
  }

  .loader {
    font-size: 52px;
  }

  .loader-text span.char {
    font-size: 80px;
  }
}

@media (min-width: 1440px) {
  .navbar-main {
    max-width: 1400px;
  }

  .logo-text {
    font-size: 32px;
  }
}
.nav-link-pink {
  position: relative;
  color: #ff1a57;
  overflow: hidden;
  z-index: 1;
}

.nav-link-pink::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  width: 0%;
  height: 100%;
  background-color: #ff1a57;
  z-index: -1;
  transform: translateX(-50%);
  transition: width 0.4s ease;
}

.nav-link-pink:hover {
  color: white;
}

.nav-link-pink:hover::before {
  width: 110%;
}
